package cn.iocoder.yudao.module.shop.service.itemtimesrecharge;

import java.time.LocalDateTime;
import java.util.*;
import javax.validation.*;
import cn.iocoder.yudao.module.shop.controller.admin.itemtimesrecharge.vo.*;
import cn.iocoder.yudao.module.shop.dal.dataobject.itemtimesrecharge.ShopItemTimesRechargeDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;

/**
 * 项目次数充值 Service 接口
 *
 * @author 曹建伟
 */
public interface ShopItemTimesRechargeService {

    /**
     * 创建项目次数充值
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    Long createItemTimesRecharge(@Valid ShopItemTimesRechargeCreateReqVO createReqVO);

    Long timesRecharge(Long memberId, Long itemId, Integer payPrice, Integer times, String reason, Long tenantId);

    /**
     * 更新项目次数充值
     *
     * @param updateReqVO 更新信息
     */
    void updateItemTimesRecharge(@Valid ShopItemTimesRechargeUpdateReqVO updateReqVO);

    /**
     * 删除项目次数充值
     *
     * @param id 编号
     */
    void deleteItemTimesRecharge(Long id);

    /**
     * 获得项目次数充值
     *
     * @param id 编号
     * @return 项目次数充值
     */
    ShopItemTimesRechargeDO getItemTimesRecharge(Long id);

    /**
     * 获得项目次数充值列表
     *
     * @param ids 编号
     * @return 项目次数充值列表
     */
    List<ShopItemTimesRechargeDO> getItemTimesRechargeList(Collection<Long> ids);

    /**
     * 获得项目次数充值分页
     *
     * @param pageReqVO 分页查询
     * @return 项目次数充值分页
     */
    PageResult<ShopItemTimesRechargeDO> getItemTimesRechargePage(ShopItemTimesRechargePageReqVO pageReqVO);

    /**
     * 获得项目次数充值列表, 用于 Excel 导出
     *
     * @param exportReqVO 查询条件
     * @return 项目次数充值列表
     */
    List<ShopItemTimesRechargeDO> getItemTimesRechargeList(ShopItemTimesRechargeExportReqVO exportReqVO);

    /**
     * 获取某个时间点之后充值次数
     *
     *
     * @return 充值次数
     */
    Long getChargeCount(Long memberId);

}
